<?php

namespace app\admin\model\scanwork;

use think\Model;

/**
 * 库存记录模型
 */
class InventoryRecord extends Model
{
    // 表名
    protected $name = 'scanwork_inventory_record';
    
    // 自动写入时间戳字段
    protected $autoWriteTimestamp = false; // 使用自定义字段

    // 追加属性
    protected $append = [
        'type_text',
        'operate_time_text'
    ];
    
    /**
     * 类型列表
     */
    public function getTypeList()
    {
        return [
            '1' => '入库',
            '2' => '出库',
            '3' => '调整'
        ];
    }

    /**
     * 类型文本
     */
    public function getTypeTextAttr($value, $data)
    {
        $value = $value ? $value : (isset($data['type']) ? $data['type'] : '');
        $list = $this->getTypeList();
        return isset($list[$value]) ? $list[$value] : '';
    }

    /**
     * 操作时间文本
     */
    public function getOperateTimeTextAttr($value, $data)
    {
        $value = $value ? $value : (isset($data['operate_time']) ? $data['operate_time'] : '');
        return $value ? date('Y-m-d H:i:s', $value) : '';
    }

    /**
     * 关联物料
     */
    public function material()
    {
        return $this->belongsTo('Material', 'material_id', 'id');
    }

    /**
     * 关联入库单
     */
    public function inbound()
    {
        return $this->belongsTo('PurchaseInbound', 'inbound_id', 'id');
    }

    /**
     * 关联操作员
     */
    public function operator()
    {
        return $this->belongsTo('app\admin\model\Admin', 'operator_id', 'id');
    }
}
